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ASSIST CHANNEL CODING WITH CHARACTER CLASSIFICATIONS 

CROSS-REFERENCE TO RELATED APPLICATIONS 

Cross-reference is made to U.S. Patent Application Serial Nos. 
09/BBB.BBB, entitled "Assist Channel Coding With Vertical Block Error 
Correction" (Attorney Docket No. D/A0039), 09/CCC,CCC, entitled "Assist 
Channel Coding With Convolution Coding" (Attorney Docket No. D/A0040), and 
09/DDD.DDD, entitled "Assist Channel Coding Using A Rewrite Model" (Attorney 
Docket No. D/A0041), which are hereby incorporated by reference. 

BACKGROUND OF THE INVENTION 

1 . Field of the Invention 

The present invention relates generally to document image encoding and 
decoding, and more particularly, to a method and apparatus for improving 
accuracy of optical character recognition (OCR). 

2. Description of Related Art 

Input scanners have been developed for uploading hardcopy documents 
into electronic document processing systems. These scanners typically convert 
the appearance of a hardcopy document into a raster formatted, digital data 
stream, thereby providing a bitmapped representation of the hardcopy document 
appearance. OCR systems such as Textbridge produced by ScanSoft, Inc. 
convert bitmapped document appearances into corresponding symbolic 
encodings. Unfortunately, OCR systems are not immune to making errors when 
inferring a correlation between a particular bitmap pattern and a corresponding 
document encoding (e.g., ASCII). 

This problem has been address by designing special fonts such as OCR- 
B fonts, where characters that are likely to be confused (e.g., 1, I, and I) are 
given distinctly different typographic features. This allows an OCR system to 
more accurately infer the correlation between a bitmap pattern and its 



corresponding document encoding. In addition, Plumb et al. disclose in "Tools for 
Publishing Source Code via OCR," 1997, printing the primary channel of a 
hardcopy document by replacing spaces and tabs with printable characters. 
Also, U.S. Patent No. 4,105,997 discloses a method for using checksums of text 
in a document to locate errors during OCR. 

This problem has also been addressed in U.S. Patent No. 5,486,686, 
which discloses a document processing system in which human readable 
hardcopy renderings of a document are integrated with complete or partial 
electronic representations of the document and/or its content. The electronic 
representation provides an "assist channel" that encodes information about the 
document or computed from the document. The assist channel is defined using 
printable machine-readable codes. In one illustrated example, the assist channel 
can be defined using compact glyph codes at the bottom of a document. 

More specifically, an "assist channel" of a hardcopy document is a 
machine readable encoding of side information that aids an OCR application in 
decoding the contents of a primary channel. The "primary channel" of a hardcopy 
document includes the human readable information of document. The primary 
channel, which cannot be modified and is slightly error prone to OCR processing, 
carries most of the information content of the document. One use of the assist 
channel is to encode information that assists in the identification of failures of an 
OCR application in decoding the contents of a primary channel as disclosed for 
example in U.S. Patent Nos. 5,625,721; 5,748,807; and 6,047,093. 

Even with these advances that improve OCR processing using an assist 
channel, it continues to be desirable to provide an assist channel encoding that 
balances and improves the tradeoff between the amount of information encoded 
in the assist channel and the improved accuracy of the OCR system given the 
encoded information. At one extreme, the assist channel can contain as much 
information as the primary channel (i.e., redundant information). At the other 
extreme, the assist channel can simply contain a single checksum of the 
contents of a document. There exists therefore the desirability to provide an 



assist channel encoding that compensates for the failure of the primary channel 
during OCR processing yet is compact relative to the primary channel. 

SUMMARY OF THE INVENTION 

In accordance with the invention, there is provided a method, and 
5 apparatus therefor, for generating image data for rendering on a hardcopy 
document. A primary set of symbol data is identified that provides a first channel 
of human readable information to be rendered on the hardcopy document. A 
secondary set of encoding data is computed from the primary set of symbol data. 
The secondary set of encoding data provides an assist channel of machine 
10 readable information that is rendered on the hardcopy document. 

In accordance with one aspect of the invention, the assist channel is 
encoded by partitioning the primary set of symbol data into a plurality of groups. 
The plurality of groups classify symbol data according to how likely the symbol 
data will occur in the hardcopy document and how likely symbol data in the 
15 primary set of symbol data are to be confused during processing of a scanned 
representation of the symbol data. The secondary set of encoding data is 
developed by associating the symbol data with ones of the plurality of groups. 

In accordance with another aspect of the invention, the assist channel is 
decoded by identifying a shortest path graph of a product graph of the primary 
20 set of symbol data and the secondary set of encoding data of the scanned 
representation of the hardcopy document. The product graph eliminates 
template matches with the primary set of symbol data that are inconsistent with 
the secondary set of encoding data. 

BRIEF DESCRIPTION OF THE DRAWINGS 

25 These and other aspects of the invention will become apparent from the 

following description read in conjunction with the accompanying drawings 
wherein the same reference numerals have been applied to like parts and in 
which: 
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Figure 1 illustrates the exchange of an electronic document that is viewed 
and/or created on a display; 

Figure 2 illustrates the exchange of a hardcopy document, with data from 
a primary channel and an assist channel rendered thereon, between the 
5 hardcopy domain and the electronic domain; 

Figure 3 is a flow diagram of the general steps for carrying out separation 
encoding in accordance with the present invention. 

Figure 4 is a flow diagram that sets forth step 308 shown in Figure 3 in 
greater detail; 

10 Figure 5 illustrates an example of a graph of an identified alphabet of four 

symbols "e", "p", "b", and "c" with corresponding nodes that record the probability 
that a character will occur; 

Figure 6 is a graph that illustrates the iterative process for identifying a 
current partition which minimizes entropy while maximizing benefit; 

15 Figure 7 illustrates a partition in which a set of symbols is arranged into 

three groups; 

Figure 8 illustrates an example of a primary channel; 

Figure 9 illustrates an assist channel for the primary channel shown in 
Figure 8 that is developed using the partition illustrated in Figure 7; 

20 Figure 10 illustrates an example of an assist channel that is encoded 

using data glyphs; 

Figure 11 illustrates a flow diagram of the steps performed by the 
hardcopy assist channel for decoding the primary channel of the hardcopy 
document augmented with the assist channel; 

25 Figure 12 is a flow diagram that sets forth the steps for computing the 

shortest path of a graph of a primary channel; 

Figure 13 illustrates a graph with nodes for a bitmap representation of the 
character 802 of the line of the primary channel 800 shown in Figure 8; 
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Figure 14 illustrates an example of a forward pass computation using the 
Viterbi algorithm; 

Figure 15 illustrates an example of backtracing (i.e., backward pass 
computation of the Viterbi algorithm) of the graph developed in Figure 14; 

Figure 16 illustrates an example a shortest path computation of a product 

graph; 

Figure 17 is a flow diagram of the steps for carrying out block encoding of 
an assist channel; 

Figure 18 illustrates an example of a primary channel of data; 

Figure 19 illustrates an example in which guard digits are computed for 
specified vertical blocks of symbol data of the primary channel shown in Figure 
18; 

Figure 20 illustrates data assembled for the example primary channel of 
data shown in Figure 1 8; 

Figure 21 is a flow diagram that sets forth the steps performed by the 
hardcopy assist channel for decoding a scanned hardcopy document with a 
block encoded assist channel; 

Figure 22 illustrates a detailed example of a reinterpretation of a shortest 
path computation performed for a portion of the primary channel shown in Figure 
18; 

Figure 23 is a flow diagram of the steps for carrying out convolution 
encoding of an assist channel; 

Figure 24 illustrates a simplified embodiment of the computation of the 
state change function and the guard extractor function for a current line of a 
primary channel (i.e., "This") for the case where the number of bits of the guard 
value qj=1 ; 



Figure 25 illustrates a more generalized representation of the recurrent 
computation performed to produce guard values for each corresponding 
character code in a line of a primary channel; 

Figure 26 illustrates a flow diagram that sets forth the steps performed by 
5 the hardcopy assist channel shown in Figure 2 for decoding a scanned hardcopy 
document with a convolution encoded assist channel; 

Figure 27 is a flow diagram that sets forth the step 2610 shown in Figure 
26 in greater detail; 

Figure 28 illustrates a graphical representation of the method for decoding 
10 the current line of the primary channel shown in Figure 24 according to the steps 
shown in Figure 27; 

Figure 29 illustrates the convolution coder shown in Figure 25 with 
integrated separation coders and separation code compressors, which is 
referred to herein as "modulated convolution coding"; 

15 Figure 30 illustrates an example of the scrambling of separation codes 

that are compressed with arithmetic encoding using the guard values; 

Figure 31 is a flow diagram that sets forth the details of step 2610 shown 
in Figure 26 for decoding each line of the primary channel with a scrambled 
convolution coded assist channel; 

20 Figure 32 illustrates an alternate embodiment of the hardcopy assist 

channel shown in Figure 2; 

Figure 33 illustrates an event library that is used to build a failure model 
for the OCR engine in the decoder module; 

Figure 34 is a flow diagram that sets forth the steps for defining a graph 
25 performed by the rewrite module shown in Figure 32 using the event library 
shown in Figure 33; 

Figure 35 illustrates an example of a graph defined in accordance with 
the steps set forth in Figure 34; and 
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Figure 36 illustrates an example of the decoding of the graph defined with 
the steps 1201 set forth in Figure 12. 

DETAILED DESCRIPTION 

A. Assist Channel Operating Environment 

5 Figures 1 and 2 illustrate the general operating environment of the present 

invention, in which documents are exchanged between the electronic and the 
hardcopy domain. Figure 1 illustrates an electronic document 102 that is viewed 
and/or created on a display 104, or the like, and a hardcopy document 106 that 
is rendered on a physical medium such as paper by a printer 108. An electronic 
10 assist channel 110 receives image data from an electronic document processing 
system (not shown) that is used for creating and/or editing the electronic 
document 102 and produces as output augmented image data 122. 

The image data input to the electronic assist channel 110 is defined 
herein as primary channel 112 data that includes the image data 114 of the 

15 electronic document 102. An encoding/compression module 1 1 6 of the electronic 
assist channel 110 produces an assist channel 1 18. A merge module 120 of the 
electronic assist channel 110 merges the primary channel 112 with the assist 
channel 118 to produce the augmented image data 122. In this embodiment 
shown in Figure 1, the primary channel 112 and the assist channel 118 of the 

20 augmented image data 122 is rendered on the hardcopy document 106 at 124 
and 126, respectively. The primary channel data 124 is optimized to be human 
readable information, whereas the assist channel data 126 is optimized to be 
machine readable information. 

Figure 2 illustrates the uploading of the hardcopy document 106, with data 
25 from a primary channel 124 and an assist channel 126 rendered thereon, from 
the hardcopy domain to the electronic domain. In accordance with one aspect of 
the invention, a hardcopy assist channel 204 receives bitmap image data 206 
from scanner 208. An image extraction module 210 in the hardcopy assist 
channel 204 separates the assist channel 1 18 data from bitmap primary channel 
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214 data. A decoding/decompression module 212 in the hardcopy assist channel 
204 prepares the assist channel 1 18 data for use by decoder module 216. 

The decoder module 216 performs Optical Character Recognition (OCR) 
on the bitmap primary channel 214 using decoded and decompressed assist 
channel 219 to produce primary channel data 112. Once accurately 
reconstructed using the assist channel 119, the primary channel data 1 12 can be 
displayed on display 104 as image data 114. Accordingly, the assist channel 
modules 110 and 204 aid in performing OCR processing of hardcopy document 
image data that converts data between the hardcopy and electronic domains. 

It will be appreciated by those skilled in the art that there exits multiple 
operating arrangements of the assist channel modules 110 and 204 shown in 
Figures 1 and 2. In some embodiments, the assist channel modules 110 and 204 
are embedded in computer systems that operate integral with the display 104 or 
the printer 108, or that operate separate from the display 104 and printer 108. In 
other embodiments, the assist channel modules 110 and 204 operate integral 
with each other or separate from each other on one or more computer systems. 

B. Assist Channel Coding 

By way of overview, assist channel coding compresses information 
content of a primary channel in the assist channel with only that information that 
may be missing or needed during OCR processing of the primary channel. That 
is, unlike techniques that can be used to compress a duplicate primary channel, 
the assist channel improves encoding efficiency by minimizing the content of the 
assist channel. Also, unlike progressive encoding (or pyramid encoding), where 
the primary and secondary channels are designed to deliver information 
progressively, assist channel coding begins with a fixed channel of data and 
augments that data with data that compensates for errors or omissions 
encountered when converting from the hardcopy domain to the electronic 
domain. 

Disclosed below in sections C, D, and E are three different methods for 
encoding and decoding assist channel data. By way of overview, Figures 3-16 



illustrate assist channel coding/decoding using separation coding; Figures 17-22 
illustrate assist channel coding/decoding using block coding; and Figures 23-28 
illustrate assist channel coding/decoding using convolution coding. Section F 
describes an alternate operating environment which uses a "rewrite model" in 
5 which these decoding techniques can be applied. 

C. Assist Channel Separation Coding 

A first method of assist channel coding, referred to herein as "separation 
coding", classifies the symbols in primary channel that are most likely to be 
confused during OCR processing into different groups (i.e., equivalence 

10 classes). Advantageously, classifications of characters into equivalence classes, 
which may be readily compressed, are encoded in the assist channel and not the 
actual character codes, which may not be compressed as well. When decoding a 
scanned representation of the primary channel, the allowable symbol matches 
from a template library are restricted during OCR to those that satisfy the 

15 classifications encoded in the assist channel, thereby improving OCR reliability. 

C.1 Assist Channel Separation Encoding 

Figure 3 is a flow diagram of the general steps for carrying out separation 
encoding. Generally, separation coding can be divided into two distinct 
operations: defining an encoding and applying the encoding. Operations for 

20 defining an encoding, which are identified by the block of steps 304, involve the 
generation of a collection of equivalence classes that separate the characters or 
symbols in the primary channel that are most likely to be confused during OCR 
processing. Operations, which are identified by the block of steps 312, for 
applying the encoding developed at steps 304, involve assigning characters or 

25 symbols in the primary channel to an equivalence class from the collection of 
defined equivalence classes. 

By way of overview, the operations for defining an encoding at steps 304 
may be performed with, or independent from, the operations for applying the 
encoding at steps 312. In fact, steps 304 need only be performed once for any 
30 number of times an assist channel is created for a particular primary channel, 
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while steps 312 are required to be performed each time an assist channel is 
created for a primary channel. As will be discussed in greater detail below, an 
encoding need not be defined each time it is applied at steps 312. 

More specifically at step 306, an alphabet of (alphanumeric) symbols (i.e., 
symbol data) that may appear in a primary channel of a set of electronic 
documents is identified. Subsequently at step 308, the identified alphabet of 
symbols is partitioned into a plurality of groups that minimize entropy and 
maximize benefit. That is at step 308, the alphabet of symbols is mapped to one 
of a plurality of equivalence classes (i.e., groups) in a manner that (a) minimizes 
the amount of information that makes up the assist channel (i.e., entropy) and (b) 
that maximizes the probability that two characters, which are likely to be 
confused during OCR processing, are placed in different equivalence classes 
(i.e., benefit). 

Figure 4 is a flow diagram that sets forth step 308 shown in Figure 3 for 
partitioning the identified alphabet of alphanumeric symbols into a plurality of 
groups in greater detail. At step 410, a graph is defined that includes a node that 
corresponds to each character in the identified alphabet of symbols and arcs that 
interconnect each node. Figure 5 illustrates an example of a graph 500 of an 
identified alphabet of four symbols "e", "p", "b", and "c" with corresponding nodes 
502, 504, 506, and 508, respectively, that record the probability that a character 
will occur. Each node has an arc to another node that records the benefit of one 
character being separated from the other character. For example, node 502 has 
arcs 510, 512, and 514 to nodes 504, 506, and 508, respectively, that record that 
benefit that each is separated from the other into different equivalence classes. 

At step 412 in Figure 4, the nodes and arcs defined at step 410 are 
assigned values. More specifically, each node is assigned a value defined by the 
probability that a character will occur in a document. Each arc is assigned a 
value that is defined by the likelihood that the characters at the ends of the arc 
will be confused during OCR processing. At step 414, all the nodes are 
assembled in a single group to define a current partition of the nodes. The 
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current partition is adjusted at steps 416, 418, 420, and 422 in a manner that 
minimizes entropy and maximizes benefit. 

At step 416, all possible changes in the current partition of the graph are 
identified. In one embodiment, possible changes are identified by (a) forming a 
new group of any node from any existing group; and (b) moving a node from one 
group to another group. At step 418, for each of the possible candidates 
identified at step 416, the change in benefit and change in entropy are 
computed. Each candidate includes one or more possible changes that define a 
new partition. At step 420, the current partition is selected to be that partition that 
maximizes the ratio of change in benefit to the change in entropy. 

More specifically at step 420, the current partition is selected from those 
candidates defined by the changes identified at step 416 so that the ratio of the 
reduction in OCR errors to the size of the information content of the assist 
channel is maximized. Referring again to Figure 5, the current partition of the 
graph 500 includes groups 516 and 518. At step 422, if the desired benefit or 
entropy is achieved then the routine terminates with the current partition being 
the partition of the identified alphabet of symbols that minimizes entropy and 
maximizes benefit at step 308. 

Figure 6 is a graph that illustrates the iterative process for identifying the 
current partition that minimizes entropy while maximizing benefit. Initially, the 
current partition is represented by point 600 on the graph (step 414). After a first 
set of candidates 602 are identified (step 418), the candidate 604 that maximizes 
the entropy to benefit ratio is selected (step 420). This process continues 
iteratively for candidates 606, 608, and 610, until candidate 612 is identified with 
the desired benefit or entropy (step 422). It will be appreciated by those skilled in 
the art that this process will take into account the instances when a candidate, 
such as hypothetical candidate 614, results in a ratio that is locally negative 
relative to the prior current partition 616. In the example shown in Figure 6, 
choosing such a candidate would therefore be preferred over choosing any of 
the candidates 608 with positive slopes. 



Referring again to Figure 3, step 310 is executed once the identified 
alphabet of alphanumeric symbols is partitioned into groups that minimizes 
entropy while maximizing benefit at step 308. At step 310, an identifier is 
assigned to each of the plurality of groups of the partition developed at step 308. 
5 Figure 7 illustrates a partition 700 in which a set of symbols is arranged into 
three groups 702, 704, and 706 (step 308). The groups 702, 704, and 706 are 
assigned the identifiers 708, 710, and 712, respectively (step 310). The partition 
700 maximize benefit by separating the symbols "e", "o", and "c" identified by 
reference numbers 714, 716, and 718, which are likely to be confused by an 
10 OCR process, into groups 702, 704, and 706, respectively. In addition, the 
partition 700 minimizes entropy by defining three groups that assemble in the 
largest group 702 those symbols that have the greatest probability of occurring in 
a document. 

An example of a partition of the ASCII character set is set forth in Table 1 
15 into which the ASCII character set is divided into nine groups of characters. As 
set forth above, the characters that are easily confused during OCR processing, 
"e", "c", and "o" are separated into groups or classes with identifiers (i.e., IDs) Z1 , 
72, and Z4, respectively, to maximize benefit. In addition, the characters most 
likely to occur in the first and largest group identified as Z1 minimize entropy, 
20 thereby minimizing the amount of information content in the assist channel. 



Table 1 



ID 


Symbol Group 


Z1 


space,%,@,A,B,D,F,G,H,K,M,N,0, 
P,S,T,W,a,d,e,g,h,i,k,m,n„s,t,u,w,x 

>y 


Z2 


$,&„,6,8,?,C,E,L,R,U,V,X,Y,b,c,f,j,l 
,p,q,v,z 


Z3 


! * 7 • < = >\ A 


Z4 


#,.,0,3,5,9,l,Q,o 
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"7 c; 


(,), -,2,4,-^,2 


Z.O 


11 / i f 1 1 


77 


4- 1 ' 


Z8 




Z9 


[ 



Because the steps 304 examine only local changes at step 416, this 
technique for defining partitions will not always arrive at the global optimal 
tradeoff between benefit and entropy. While algorithmic techniques such as 
5 simulated annealing or branch and bound may be used to find better solutions, 
these approaches offer slightly improved solutions to the technique set forth at 
steps 304 but require considerably more time to find a solution. Consequently, 
the steps 304 are very well suited for this application for identifying graph 
partitions. 

10 Once the defining steps 304 have completed, the applying steps 312 are 

performed. Initially at step 314, an assist channel is developed by associating 
each symbol of the primary channel received at step 302 with an identifier 
corresponding to the group in which each symbol is assigned. Figure 8 illustrates 
an example of a primary channel 800 received at step 304. Figure 9 illustrates an 

15 assist channel 900 for the primary channel shown in Figure 8 that is developed 
using the partition 700 illustrated in Figure 7. Specifically, the first two symbols 
"A" and "n" from the primary channel 800, identified by reference number 802 
and 804, are classified in groups 702 and 704 with the identifiers 708 (i.e., "a") 
and 710 (i.e., "b"), which are identified by the reference numbers 902 and 904 in 

20 Figure 9, respectively. 

At step 316, the assist channel developed at step 314 is compressed 
using, for example, arithmetic encoding, Ziv-Lempel encoding, or run length 
encoding. These and other compression techniques are disclosed by Cover et 
al., in "Elements of Information Theory," John Wiley & Sons, August 12, 1991 
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(ISBN: 0471062596), which is incorporated herein by reference. Once the assist 
channel is compressed at step 316, it is encoded at step 318. In one 
embodiment, the assist channel is encoded using data glyphs. Figure 10 
illustrates an example of an assist channel 1010 that is encoded using data 
glyphs. 

Data glyphs referred to herein encode digital information in the form of 
binary ones and zeros that are then rendered in the form of very small linear 
marks. Generally, each small mark represents a digit of binary data. Whether the 
particular digit is a binary one or zero depends on the linear orientation of the 
particular mark. For example, in one embodiment, marks oriented from top left to 
bottom right may represent a zero, while marks oriented from bottom left to top 
right may represent a one. 

The individual marks of data glyphs, which form the assist channel 126 
shown in Figures 1 and 2, are of such a size relative to the maximum resolution 
of a printing device as to preferably produce an overall visual affect to a casual 
observer of a uniform gray halftone area when a large number of such marks are 
printed together on paper. U.S. Patent Nos. 5,091,966, 5,128,525, 5,168,147, 
5,221,833, 5,245,165, 5,315,098, 5,449,895, and 5,486,686, which are hereby 
incorporated by reference, provide additional information about the uses, 
encoding, and decoding techniques of data glyphs. 

Referring again to Figure 3, at step 320 encoded data glyphs are 
concatenated with the primary channel to produce augmented data. The 
concatenated channels (i.e., augmented data) are rendered on a hardcopy 
document. As shown in Figure 1 in one embodiment, the augmented data 122 is 
rendered by printer 108 on hardcopy document 106 as primary channel 124 and 
assist channel 126. 

It will be appreciated by those skilled in the art that the defining steps 304 
need not be performed each time the applying steps 312 are performed for a 
primary channel received at step 302. Instead, defining steps 304 need only be 
performed once for any number of primary channels. Alternatively, defining steps 
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304 can be performed intermittently as the alphabet or font of the alphanumeric 
symbols received at step 302 changes. 

In another embodiment, the defining steps 304 are performed once for 
different categories of documents, fonts, or machines. For example, the defining 
5 steps may be performed once for per font typeface and repeatedly applied at 
steps 312. Also by way of example, categories of documents may include 
categorization by the genre of document (e.g., office documents, legal 
documents, memos, images, etc.). Further by way of example, categories of 
machines include specific scanner and printers, or classes of scanners and 
10 printers. For example, the defining steps 304 in one embodiment may be 
performed for a specific scanner and/or printer, thereby sensitizing the encoding 
scheme to particular failures of the specific scanner and/or printer. 

C.2 Assist Channel Separation Decoding 

Figure 11 illustrates a flow diagram of the steps performed by the 
15 hardcopy assist channel for decoding the primary channel 124 of the hardcopy 
document 106 augmented with the assist channel 126, which is shown in Figure 
2. Initially at step 1102, a bitmap image 206 of the hardcopy document 106 is 
acquired using, for example, scanner 208. At step 1104, the image extraction 
module 21 0 extracts the assist channel from the bitmap image 206 to provide the 
20 assist channel 118 to the decoding/decompression module 212. In addition, the 
image extraction module 210 extracts a bitmap primary channel 214, which is a 
bitmap representation of the primary channel 124, from the bitmap image 206. 

At step 1 106, the assist channel is decoded by module 212. For example, 
if the assist channel is encoded using data glyphs, those data glyphs are 
25 decoded at step 1 106 to their digital representation. The assist channel (now in a 
digital form) is decompressed at step 1108 by module 212 to provide to the 
decoder module 216 a decoded and decompressed assist channel 219. 

Beginning at step 1110, the decoder module 216 acquires as input 
successive lines of the bitmap primary channel 214 and corresponding 
30 successive lines of the decoded and decompressed assist channel 219 from 
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modules 210 and 212, respectively. For each the successive lines of channels 
214 and 219 received at step 1110, steps 1112, 1114, and 1116 are executed 
until all lines of the primary channel 214 have been processed at step 1118, at 
which point, decoding of the primary channel completes at step 1120. Once the 
5 decoder module 216 completes at step 1120, a decoded primary channel 112 
can be viewed in electronic form on display 104 as 1 14 in document 102. 

With specific reference now to steps 1 1 1 2, 1 1 1 4, and 1 1 1 6 for decoding a 
line of the bitmap primary channel 214. At step 1112, a graph of the line the 
primary is determined to define a first dimension of a product graph. At step 
10 1114, a graph of the corresponding line of the assist channel is determined to 
define a second dimension of the product graph. Finally at step 1116, the 
shortest path of the product of the graph of the primary channel and the graph of 
the assist channel is determined to produce an observed primary channel. 

In one embodiment, step 1112 (for each line of "text" of the bitmap 
15 primary channel 214) is performed by the decoder module 216 using a document 
decoding technique known in the art as Document Image Decoding (DID). In 
general, DID is accomplished using dynamic programming or the Viterbi 
algorithm. The dynamic programming involves the search for a path through a 
finite state network representing an observed image (i.e., primary channel 112) 
20 that is the most likely path that would produce the observed image (i.e., the most 
likely observed image that could have come from the bitmap primary channel 
214). 

Further details of dynamic programming are disclosed in "The Design and 
Analysis of Computer Algorithms" (Addison-Wesley Series in Computer Science 

25 and Information Processing) by Aho, Hopcroft, and Ullman, Addison-Wesley Pub 
Co., ISBN: 0201000296, June 1974, the pertinent portions of which are 
incorporated herein by reference. In addition, further details of DID are disclosed 
in U.S. Patent Nos.: 5,321,773; 5,526,444; 5,689,620; and 5,594,809; which are 
incorporated herein by reference, and in U.S. Patent Application Serial Nos.: 

30 09/EEE.EEE, entitled "Document Image Decoding Using An Integrated 
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Stochastic Language Model" (Attorney Docket No. D/99463); 09/FFF,FFF, 
entitled "Dynamic Programming Operation With Skip Mode For Text Line Image 
Decoding" (Attorney Docket No. D/99464); and 09/GGG,GGG, entitled 
"Document Image Decoding Using Text Line Column-Based Heuristic Scoring" 
5 (Attorney Docket No. D/99466); which are also incorporated herein by reference. 

Referring now to Figure 12, which is a flow diagram that sets forth the 
steps for computing the shortest path of a graph of a primary channel using a 
Viterbi algorithm. Initially, a graph is defined at steps 1200 and a shortest path of 
the defined graph is computed at steps 1201 . Figure 12 describes a DID decoder 

10 that operates without the assistance of an assist channel. To include an assist 
channel, the graph defined in steps 1200 is modified by computing a product 
graph before the shortest path is computed. Referring now to the steps in Figure 
11, the steps 1200 are performed at step 1112 to determine a graph for the 
primary channel. In addition, the steps 1201 are performed at step 1116 to 

15 determine the shortest path of a graph defining the product of the graphs of the 
primary and assist channels. 

The definition of a graph begins at step 1202 by defining nodes of the 
graph at every pixel along a line of the bitmap primary channel 214. For 
example, Figure 13 illustrates graph creation at 1301 and shortest path 

20 computation at 1303. Graph creation begins by defining a graph 1300 with nodes 
1302 for the bitmap representation of the character 802 of the line of the primary 
channel 800 shown in Figure 8. At step 1203, at each node all possible arcs are 
enumerated using a template library. At step 1204, an arc score is computed at 
each of the enumerated arcs by matching the character in the template library 

25 with the character in the image. 

More specifically, the arc score is computed for each enumerated arc 
using a matching function. This computation is a measurement of the match 
between a particular template in the library and the image region at the image 
point defined by the node. While there is some flexibility in choosing a matching 
30 function, it is usually closely proportional to the minus logarithmic probability of 
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the match. This allows the score of the arc to be smaller for better matches, and 
the shortest path to identify the best interpretation of the entire line. An example 
of a matching function is disclosed in by Kopec et al. in "Document Image 
Decoding Using Markov Source Models," IEEE Transactions on Pattern Analysis 
5 and Machine Intelligence, Vol. 16, No. 6, June 1994, pp. 602-617, which is 
incorporated herein by reference. 

The arc score and template is recorded in the form of an arc to another 
node. For example as shown in Figure 13, arc 1314 is defined between nodes 
1306 and 1308 by template 1310 (i.e., "A") and an arc score 1312 (i.e., "10"). 
10 More specifically, arcs are weighted by the quality of the match (the lower the 
score the better the match) and they connect nodes with positions separated by 
the width of the template identified by the match. 

In order to accommodate slight shifts in spacing between adjacent 
templates, spacer arcs (identified in Figure 13 by reference number 1316) are 
15 defined. For example, spacer arc 1318, which also has a score (not shown) may 
fill a spacing between the terminal node 1308 of template 1310 and a 
subsequent template for character 804 shown in Figure 8 that may begin at node 
1320. 

At step 1206, a record 1322 is defined as shown with a cumulative score 
20 1324 and a backpointer 1326 for each node 1302 (as shown at shortest path 
computation 1303 in Figure 13). At step 1208, all the records 1322 of the nodes 
1316 except for the last node of the line 1328 are initialized with an infinite score 
(i.e., the worst possible score or path) and a NIL backpointer. The score for the 
record for the last node of the line 1328 is initialized at step 1208 to zero (i.e., the 
25 best possible score or path). 

At steps 1210 and 1212, the two passes of the Viterbi algorithm are 
performed. During the first pass (i.e., forward pass) of the Viterbi algorithm 
performed at step 1210, the most likely path (i.e., best score) for arriving at each 
node (i.e., pixel position) is identified by using the most likely (i.e., shortest) path 
30 for arriving at all previously computed positions. The first pass is carried out until 
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the end-point of the best path for each node is identified. In the description 
referring to Figures 14 and 15 below, it will be appreciated by those skilled in the 
art that in this instance it is useful to build the partial shortest path from the back 
of a graph, thereby reversing the typical direction of the first and second pass of 
the Viterbi algorithm. 

Figure 14 illustrates an example of forward pass computation of the 
Viterbi algorithm of a graph 1400 defined by nodes 1402. The forward pass is 
performed in the direction indicated by arrow 1404 (i.e., forward or first direction) 
from node 1403 to node 1401. For simplicity, only the scores 1416 and 1418 and 
templates 1420 and 1422 for arcs 1406 and 1408 starting at nodes 1410 and 
1412, respectively, and terminating at node 1414 are shown. In computing the 
shortest path for the node 1414 at step 1210, a determination is made as to 
whether the score and backpointers in records 1424 and 1426 of nodes 1410 
and 1412, respectively, should be updated to point to node 1414 to define a 
shorter path. If updated the new score of node 1410 would be 19 (i.e., 12 + 7) 
while if updated the new score of node 1412 would be 10 (i.e., 3 + 7). Because 
the score of node 1410 would be improved if updated, it is updated with a new 
score and backpointer (see Figure 15) to node 1414 (i.e., 19 is better than 50). In 
contrast, the score of node 1412 would not be improved if updated with the new 
score from node 1414, and it is therefore not updated (i.e., 10 is worse than 8). 

During the second pass (i.e., backwards pass) of the Viterbi algorithm 
performed at step 1212, the graph constructed during the first pass is backtraced 
from the first node of the graph to identify the actual best path (i.e., shortest) 
through the graph. Figure 15 illustrates an example of backtracing of the graph 
1400 developed in Figure 14. Backtracing is performed in Figure 15 in the 
direction indicated by arrow 1503. Although many different paths may exist, the 
best path is defined by backtracing the path through the graph that begins at the 
backpointer of the last node processed during the first pass (i.e., backpointer 
1504 of node 1401). From the backpointer 1504 of the node 1401, a path of 
backpointers (e.g., 1504, 1506, 1508, 1510, 1512) that identifies a set of arcs 
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(e.g., backpointer 1508 identifies arc 1406) that specify a template of a character 
(e.g., template 1420). This set of arcs identifies templates that match symbols of 
the primary channel. That is, the shortest path of the first dimension of the 
product graph defines an output string that is formulated without assistance of 
5 the assist channel 219. 

To incorporate an assist channel in the product graph, the computation of 
the shortest path 1201 is deferred until the product graph is defined. At step 
1114, a graph of the assist channel 219 is determined to define a second 
dimension of a product graph. More specifically at step 1114, nodes are defined 
10 at each of the identifiers 708 encoded in the assist channel. The arc from one 
node to the next is given the value of the identifier. In addition, each node 
includes an arc that returns to itself (i.e., a self-returning arc, e.g., arc 1630) to 
j! accommodate the presence of spacer arcs 1316 during computation of the 

Ul shortest path. 

+■ 15 Finally at step 1116, the shortest path of a product graph is defined using 

jji the one-dimensional graphs defined at steps 1112 and 1114. That is, step 1116 

m identifies a shortest path through the product graph using the bitmap primary 

0 channel 214 and the assist channel 219 to define the observed image (i.e., 

1 n 

U primary channel 112). Steps 1 1 1 0, 1 1 1 2, 1 1 1 4, and 1 1 1 6 repeat for each line in 

5 20 the bitmap primary channel 214 at step 1118. Once all lines of the primary 
□ channel have been processed at step 1120, the primary channel 112 can be 

viewed on display 104 in, for example, the document 102 as image data 1 14. 

Figure 16 illustrates an example a shortest path computation of a product 
graph at step 1116 in Figure 11. The product graph 1600 illustrated in Figure 16 

25 includes a first dimension 1602, defined by a graph produced at step 1112 in 
Figure 11, and a second dimension 1604, defined by a graph produced at step 
1114 in Figure 11. The first dimension 1602 of the product graph represents a 
bitmap line of text of the primary channel 800 shown in Figure 8 and the second 
dimension 1604 of the product graph represents a corresponding line of the 

30 assist channel 900 shown in Figure 9. 
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For illustrative purposes the product graph 1600 shown in Figure 16 only 
includes the first four symbols of the primary channel (i.e., 802, 804, 806, and 
808), the first four identifiers of the assist channel (i.e., 902, 904, 906, and 908), 
and only a few template matches. For comparison purposes, the product graph 
5 1600 illustrates both its resulting output string 1608 and the output string 
produced by computing a shortest path of the graph of the bitmap primary 
channel in the one dimension 1602, which includes a set of arcs 1610, 1612, 
1614, and 1618. Computation of the shortest path of the graph 1600 in the single 
dimension 1602 is performed without input from the assist channel and produces 
10 output string 1 606, which includes characters "Ah a". 

The product graph 1600 includes nodes 1640 that identify both position in 
the image along dimension 1602 and position in the corresponding assist 
channel along dimension 1604. Also, the product graph 1600 includes arcs that 
must be consistent with the assist channel. That is, for each arc in the first 

15 dimension with a template label and for each arc in the second dimension with a 
classification label, there exists a corresponding arc in the product graph if the 
template is the right class. The arcs 1622, 1624, 1626, and 1628 along the 
second dimension 1604 correspond to the identifiers 902, 904, 906, and 908 that 
identify the groups of symbols 702, 704, 702, and 702, respectively. Once the 

20 product graph 1600 is defined, computing the shortest path of the product graph 
produces the output string 1608, which includes characters "An a". 

As shown in Figure 16, the output of an unassisted decoded primary 
channel 1606 is corrected using the assist channel in the product graph 1600. In 
defining the product graph 1600 at node 1646, the template "h" of the arc 1612, 

25 which has a computed score of 15, is excluded by the assist channel. The arc 
1612 from the graph of the bitmap primary channel is excluded from the product 
graph because it does not satisfy the second entry in the assist channel defined 
by the arc 1624. That is, the template identified by the arc 1612 falls in the group 
702 instead of the group 706 as specified by the identifier 710 of arc 1624. 

30 Consequently for the templates illustrated in Figure 16, only the template "n" of 
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the arc 1620 that has a higher score of 19 and satisfies the second entry in the 
assist channel (i.e., arc 1624) is allowed as a valid arc at position 1642 in the 
product graph. 

More specifically with reference to the steps shown in Figure 11, Figure 16 
5 illustrates a product graph 1600 that produces decoded primary channel 1608 
from a scanned representation of primary channel 800 shown in Figure 8. Initially 
a graph of the primary channel is determined in a first dimension 1602 (step 
1112). Subsequently, a graph of the assist channel is determined in a second 
dimension (step 1114). Initially, a product graph is defined by combining the 
10 graph of the primary channel and the graph of the assist channel (step 1116). 
Determining the shortest path of the product of the graph of the primary channel 
and the graph of the assist channel produces output string 1608 (step 1116). 

It will be appreciated by those skilled in the art that only a portion of the 
arcs and nodes defining the product graph 1600 is shown for simplicity in Figure 

15 16. In one embodiment in accordance with the steps 1201 in Figure 12 for 
computing the shortest path of a graph, the shortest path of the product graph 
1600 is computed by performing a first pass in an order from bottom to top and 
right to left. In this embodiment, the first pass of the product graph assumes that 
the bottom most nodes in the product graph take priority over the right most 

20 nodes. The second pass is performed by selecting the path defined by the 
upper-left node 1644 of the product graph 1600. 

It will be appreciated by those skilled in the art that for simplicity the 
product graph 1600 does not show the plurality of arcs that extend from each of 
the nodes 1640 and identify all the possible matches that satisfy the assist 

25 channel between templates from the template library and the bitmap primary 
channel. In alternate embodiment, the number of arcs that define the product 
graph 1600 is reduced by including only those arcs extending from those nodes 
centered around the diagonal of the product graph. By allowing a generous 
amount of variance, this alternate embodiment assumes that the assist channel 

30 is used at a uniform rate across a line in the image. 
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D. Assist Channel Block Coding 

A second method of assist channel coding, referred to herein as "block 
coding", groups characters in the primary channel of a hardcopy document into 
vertical columns. Guard digits (i.e., error correcting codes) are computed for 
5 each of the vertical blocks and encoded in the assist channel of the hardcopy 
document. Decoding of the primary channel with the assist channel is 
advantageously synchronized at each vertical block. That is, desynchronization 
that may occur during OCR processing of a line of text is minimized because 
synchronization of the primary channel with the assist channel occurs at each 
10 vertical block of the primary channel. 

D.1 Assist Channel Block Encoding 

Figure 17 is a flow diagram of the steps for carrying out block encoding of 
an assist channel. In one embodiment, these steps are carried out by the 
electronic assist channel 110 shown in Figure 1. At step 1702, the 

15 encoding/compression module 116 receives a primary channel of data 112. For 
example, Figure 18 illustrates an example of a primary channel of data 1800. At 
step 1704, a column group size is specified. The column group size may be fixed 
or vary from one column group to the next. More specifically, the column group 
size identifies how many symbols (e.g., characters) define the column group 

20 along each line of the primary channel. At step 1706, the number of guard digits 
per column group is specified. It will be appreciated by those skilled in the art 
that the more guard digits specified at step 1706, the greater the number of 
errors the guard digits will be able to correct, but the larger the assist channel will 
be. 

25 At step 1708, the number of lines of symbol data (e.g., characters) in the 

primary channel is determined. Subsequently at step 1710, the length of each of 
the lines of symbol data is determined. At step 1712, the primary channel of 
symbol data is divided into vertical blocks according to the specified column 
group size. At step 1714, the number of guard digits specified per column group 

30 at step 1706 is computed for each the vertical blocks produced at step 1712. In 
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one embodiment, guard digits are computed by applying error correcting Reed- 
Solomon codes. Computation of Reed-Solomon codes is well known as 
disclosed by Peterson et al, in "Error-Correcting Codes," MIT Press, 1972, which 
is hereby incorporated by reference. 

5 For example, when five-error correcting Reed-Solomon codes with a 2 8 

symbol alphabet are applied, the maximum block size in the assist channel 
would be 255 digits including 10 guard digits (i.e., check digits). Further assume 
that 40 lines of text (i.e., symbol data) are grouped into columns with a column 
group size of two. This example then requires a block size of 90 characters (i.e., 
10 40*2+10=90), which is well less than the maximum block size of 255 digits for a 
Reed-Solomon code over a 2 8 symbol alphabet. Given this encoding scheme, 
the size of the guard digits would be one bit per character (i.e., a compression 
ratio of 8 characters to 1 guard digit) and, as long as there are no more than five 
OCR errors per block, the page should decode error free. 

15 Figure 19 illustrates an example in which guard digits are computed for 

specified vertical blocks of symbol data of the primary channel shown in Figure 
18. More specifically in Figure 19, the primary channel symbol data is divided 
into vertical blocks with a block size of two symbols wide (step 1712), as 
indicated by reference number 1902. For each of the vertical blocks of symbol 

20 data, corresponding guard digits 1904 are computed (step 1714). When a line 
(e.g., line 1906) of the primary channel does not extend as far as another line 
(e.g., line 1908), then empty symbols (e.g., empty symbol 1910) are added to 
that line to compute that column's guard digits (e.g., 1912). 

Once guard digits for each of the vertical blocks have been computed at 
25 1714, data for the assist channel is assembled and compressed. Figure 20 
illustrates data 2002 assembled at step 1716 for the example primary channel 
shown in Figure 18. More specifically, the data 2002 includes the column group 
size 2004, the number of guard digits per column group 2006, the number of 
lines of symbol data guarded 2008, a vector of line lengths 2010, and guard 
30 digits 2012. In one embodiment, some of the data 2002 (e.g., vector of line 
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lengths 2010) is compressed at step 1714 using a lossless compression 
technique. 

Once the assist channel is compressed at step 1716, it is encoded at step 
1718. In one embodiment, the assist channel is encoded using data glyphs, as 
5 shown for example in Figure 10. At step 1720, the encoded assist channel is 
concatenated with the primary channel and printed at step 1722 using for 
example printer 108. 

It will be appreciated by those skilled in the art that the manner in which 
the primary channel is encoded may vary. In one embodiment, the primary 

10 channel is divided into column groups that have a fixed size and a fixed number 
of guard digits each. In an alternate embodiment, the primary channel is divided 
column groups of varying size, and/or with a varying number of guard digits 
assigned to each column group. For example, the number of guard digits may 
vary for the end column because that column may have less characters since 

15 some lines may terminate before the last column. Also, the number of guard 
digits may be larger for a particular column if the information in that column is 
determined a priori to require a greater degree of decoding accuracy (e.g., 
column of a bank check containing the amount information). 

D.2 Assist Channel Block Decoding 

20 Figure 21 is a flow diagram that sets forth the steps performed by the 

hardcopy assist channel for decoding a scanned hardcopy document with a 
block encoded assist channel. As shown in Figure 2, initially at step 2102 a 
bitmap image 206 of hardcopy document 106 is acquired using a scanner. The 
hardcopy document 106 in this instance includes a primary channel 124 and a 

25 block-encoded assist channel 126. At step 2104, the image extraction module 
210 extracts the assist channel 118 and the bitmap primary channel 214 from 
the bitmap image 206. The assist channel 118 is decoded at step 2106 and 
decompressed at step 2108 by module 212. At step 2109, the bitmap primary 
channel is aligned using the line lengths from the vector of line lengths 2010 to 

30 synchronize lines in the primary channel with the guard digits in the assist 
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channel. Subsequently, the decompressed assist channel 219 and the bitmap 
primary channel 214 are input to decoder module 216, which performs steps 
2110, 2112, 2114, 2116, 2118, 2120, 2122, 2124, 2126 and 2128. 

At step 2110, a candidate OCR interpretation is computed via a shortest 
5 path computation for each line of the primary channel without the aid of the 
assist channel. In one embodiment, this shortest path computation is performed 
for each line using the Document Image Decoder discussed in detail above in 
Section C. More specifically, the DID performs the steps set forth in Figure 12 to 
produce a shortest path through a graph with nodes and arcs as shown in 
10 Figures 14 and 15. The shortest path identified by backtracing through the graph 
during a second of two passes provides the "unassisted" candidate OCR 
interpretation of each line. 

At step 2112, a current message vector is specified using a first column 
group of the candidate OCR interpretation. The dimensions of the column group 

15 are defined in the assist channel using the column group size and the number of 
lines of text guarded. At step 2114, guard digits that correspond to the current 
message vector are obtained from the assist channel. At step 2116, the guard 
digits obtained at step 2114 are used to check whether errors exist in the 
candidate OCR interpretation computed at step 2110. If errors exist then the 

20 current message vector is corrected using the guard digits (e.g., Reed-Solomon 
codes) at step 21 18; otherwise, step 2122 is executed. 

At step 2120, the remainder of the message vector of each line of the 
primary channel is identified that required correction at step 2118. For the 
remainder of the message vector not checked at step 2116, the shortest path 

25 computation performed at step 2110 is reinterpreted to produce a new or 
modified candidate OCR interpretation. Reinterpretation of remainder of each 
line of the primary channel is more fully described below with reference to Figure 
22. Finally, if all guard digits have been processed, then decoding terminates at 
step 2126; otherwise, decoding continues at step 2124 by specifying the current 

30 message to be the next vertical block of the candidate OCR interpretation. Once 
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step 2124 completes, step 2114 repeats for the current message and (modified) 
candidate OCR interpretation. 

Figure 22 illustrates a detailed example of a reinterpretation of a shortest 
path computation performed for a portion 1802 of the primary channel 1800 

5 shown in Figure 18. More specifically, Figure 22 illustrate how to use an assist 
channel to reinterpret and realign a candidate OCR interpretation 2206 when 
errors in OCR processing are identified. Initially, the candidate OCR 
interpretation 2206 is computed using the Document Image Decoder from an 
extracted bitmap primary channel 2204 (step 2110), which is indicated generally 

10 by arrow 2202. Note that only a portion 1802 of the extracted bitmap primary 
channel 1800 is shown in Figure 22. 

Subsequently, the guard digits 1918 for first column group 1920, shown in 
Figure 19, are used to determine whether an error exits in the decoded 
candidate OCR interpretation for that column group (step 2116), which is 

15 indicated generally by arrow 2209. Note that only the portion 1922 of the column 
group 1920, shown in Figure 19, is identified in Figure 22 as portion 2208. Using 
the guard digits to evaluate the column group that includes portion 2210, the 
guard digits corresponding to that column group are used to identify errors in the 
decoding of the bitmap portion 2208 and provide a corrected decoded portion 

20 2212 (step 21 18). 

After the first column group, any line that was corrected is reinterpreted to 
provide a new candidate OCR interpretation (step 2120), which is indicated 
generally by arrow 2213. In Figure 22, the new candidate OCR interpretation 
2214 is provided after reinterpreting the candidate OCR interpretation 2206 in 

25 view of the corrected decoded portion 2212. Using the DID discussed above with 
reference to Figure 15, reinterpretation of the candidate OCR interpretation 2206 
in view of the decoding error corrects the character "d" and replaces it with the 
characters "oP\ as identified in Figures 15 and 22 using reference numbers 1520, 
1522, and 1528, respectively. Because of the new character 1522, the graph 

30 1400 is realigned so that the new template terminates at node 1 524, as shown in 
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Figure 15. Backtracking from node 1524, reinterprets a new path of backpointers 
(e.g., 1526, 1508, 1510, 1512) that identifies a new set of arcs that specify a new 
set of templates, thereby obtaining the new candidate OCR interpretation 2214 
in Figure 22. 

5 After reinterpretation of the DID graph, the new candidate OCR 

interpretation 2214 now identifies a new template 1528 in Figures 15 and 22. 
Error identification and correction of the new candidate OCR interpretation 2214 
is conducted for the next column group, which includes the portion 2230. As 
performed for the portion 2210 of OCR interpretation 2206, the image portion 

10 2230 of OCR interpretation 2214 is first examined for errors and corrected if 
necessary, as indicated by arrow 2232. Subsequently, given that errors were 
identified and corrected at image portion 2234, the OCR interpretation 2214 is 
reinterpreted as new OCR interpretation 2236 as indicated by arrow 2238. The 
process illustrated in Figure 22 continues until each column group of the OCR 

15 interpretation has been analyzed in accordance with the flow diagram shown in 
Figure 21. 

It will be appreciated by those skilled in the art that various techniques can 
be used to reinterpret a line of OCR output. In particular, the string output of any 
OCR system can be realigned with a partially corrected line to minimize the 
20 string edit distance (i.e., the number of changes required to make one string 
identical to another) between the corrected prefix and the original OCR 
interpretation. 

Computing error correcting codes for a page, or more, of a hardcopy 
document along vertical partitions (that may vary in size), supplements the 

25 natural synchronization points at the beginning and the end of each line of text 
and/or a page. As illustrated in Figure 22, as error detection and correction 
progresses across a decoded line of text, successful corrections of the previous 
block 2212 synchronize corrections of a subsequent block 2230. 
Advantageously, by computing guard digits for vertical column groups of the 

30 primary channel, the decoder module 216 is synchronized at each column group. 



-28- 



Without the vertical column groups that provide multiple synchronization points 
along a line, the OCR decoder may incorrectly match different width characters 
and misalign with the error correcting code. In addition, the OCR decoder without 
proper synchronization may generate continuous strings of errors that may 
5 exceed the error correcting capacity of the assist channel. 

In addition, it will be appreciated by those skilled in the art that the more 
lines of text guarded per symbol block, the greater the compression achieved by 
the assist channel. Also, it will be appreciated by those skilled in the art that 
block coding requires multiple symbol lines to provide a sufficient number of 
10 synchronization points. That is, if there are only a few lines, then a set of 
synchronization points in the middle of lines can be added to the data 2002 in 
the assist channel. The synchronization points in a set of synchronization points 
S for the guard digits identify the locations of the first column group of the same or 
!**! different lines of text on one or more pages. This allows more than one column 

15 to be guarded by the same set of guard digits. For example, a page with multiple 
!{j columns of text (e.g., a newspaper) can be encoded by describing a set of 

W synchronization points that identify the start of lines of multiple columns of 

O message digits. Alternatively, the start of each line of a multi-page document with 

only a few lines per page can be described with a set of synchronization points 
« 20 that identify the start of lines on different pages. 

0 D.3 Extended Assist Channel Block Coding 

Although block error coding provides improved synchronization while 
identifying and correcting errors during OCR processing, block error coding does 
not use any information about the likely errors produced during OCR processing. 
25 Presented in this section are two alternate embodiments for extended assist 
channel block coding that use information about likely errors produced during 
OCR processing. 

In one embodiment, decoding can be performed by finding the most likely 
original message vector at step 2118 in Figure 21, rather than the nearest 
30 message vector. For example, correction of the current message vector may be 
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performed by making two corrections such as changing a "c" to an "o" and an "I" 
to a "1", rather than a single, less likely, correction. In this embodiment, the 
effective error correction per bit of the assist channel is improved. A 
disadvantage of this embodiment is that maximum likelihood decoding of block 

5 codes is computationally difficult. 

In another embodiment less computationally demanding, separation- 
coded error correction is performed by recoding the character codes. The 
character codes are recoded so that the OCR errors that are most likely to occur 
are assigned more guard digits than OCR errors that are less likely to occur. 

10 That is, more error correction is applied to those bits that are more susceptible to 
errors during OCR processing. For example, Table 2 illustrates a separation 
code with four equivalence classes, developed using the techniques set forth 
above. The four equivalence classes or group codes (i.e., GC) allow printed 
characters to be coded with two high order bits. Each group code identifies a 

15 unique equivalence class of character codes (i.e., CC) or group specific 
character codes. 



Table 2 



GC 


Character Code 


00 


!,",#,$ ) %,&,(,*,+,.,/,0,1,2,4,5,6,7,8,9 
,;,<,=,>,@,C,J,K,L,N,P,V,X,Y,Z,[,\,] 
, A ,_;,n,o,z,{,|,},~ 


01 


A,',),-^,:,?, F,H,l,M,0,W,b,c,j,t,v,x 


10 


„D,E,G,Q,R,S,T,d,e,f,g,i,k,m,u,w,y 


11 


B, ,U,a,h,l,p,q,r,s 



The two high order bits that identify the equivalence classes which 
20 separate characters are much more likely to be changed during OCR processing 
than the lower ordered bits alone. Thus, stronger error correction is applied to 
the higher ordered bits, in the vertical arrangement shown in Figure 19. 
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When encoding a hardcopy document as shown in Figure 17 for the case 
of block coding, this embodiment includes performing at step 1706, the step of 
specifying, for an encoding scheme as set forth in Table 2, the number of guard 
digits per group code and the number of guard digits per character code. For 
5 example, for approximately the same space used in a 5-digit error correcting 
code that does not use group codes, this encoding scheme enables an 8-digit 
error correcting code to be applied to the high order ("group code") 2-bits, and a 
2-digit error correcting code to be applied to the low order ("character code") 6- 
bits. 

10 In addition, when encoding a hardcopy document as shown in Figure 17, 

original character codes are recoded to their group code and character code 
representation (i.e., gc.cc). For example, the character "A" would be recoded to 
the code "<01><000000>" from, for example, an ASCII encoding. Thus, with 
respect to the vertical arrangement in Figure 19, the guard digit for G1, identified 

15 by reference number 1918, include a first set of guard digits that protect the 
group codes for the vertical column group 1920 and a second set of guard digits 
that protect the character codes for the vertical column group 1 920. 

When decoding, the decoder module is constrained to first find the best 
solution on lines with corrected high order bits to a particular equivalence class. 

20 Subsequently, the decoder module corrects the low order bits of the corrected 
high order bits. Corrections using the low order bits are constrained to correct 
only those characters that are within the identified equivalence class. In other 
words, first a decoded line is revised using the high order bits of the check digits. 
Subsequently, the line is further revised using the low order bits of the check 

25 digits. More specifically, Figure 21 would be modified in this embodiment to 
include a high order bit "outer loop" and a low order bit "inner loop" of steps 
2116,2118, and 2120. 

In an alternate embodiment, the column group size 2004 of the high order 
and low order guard digits varies. In one form of this alternate embodiment, high 
30 order bits of the guard digits are grouped in columns with a larger size (e.g., a 
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larger column group size of 4) relative to the low order bits of the guard digits 
(e.g., a smaller column group size of 2). This encoding format groups high order 
bits of different columns together to encode with a larger symbol alphabet, 
thereby maximizing the error correcting utilization of Reed-Solomon coding. 

E. Assist Channel Convolution Coding 

A third method of assist channel coding, referred to herein as "convolution 
coding", hashes each character q in a line of characters in the primary channel 
sequentially to compute a recurrence of a hash function. More specifically, at 
each position in a line of text, the current hash is combined with the current 
character code and hashed again, thereby producing a chain of hash values 
where each character influences all hash values to the right of its position in a 
line of text. Each hash value in the chain is sampled (e.g., by selecting one bit of 
each hash value) and encoded in an assist channel. Subsequently, when 
decoding a scanned representation of the primary channel, template match 
searches are limited to those interpretations that produce matching sample 
values of a corresponding hash value. The number of incorrect interpretations 
that are explored before a proper match is identified is limited because any error 
in a line will likely cause the chain of hash values to differ for the rest of that line, 
with the consequence that the sample values will be less likely to match. 

E.1 Assist Channel Convolution Encoding 

Figure 23 is a flow diagram of the steps for carrying out convolution 
encoding of an assist channel. In one embodiment, these steps are carried out 
by the electronic assist channel 110 shown in Figure 1. At step 2302, a primary 
channel of data is received at for example encoding/compression module 116. 
The primary channel of data may contain any alphanumeric symbol that may be 
created on a hardcopy document by a printer, or the like. At step 2304, a current 
line of the primary channel of character data is selected. At step 2306, 2308, 
2310, 2312, 2314 and 2316, each line of the primary channel is encoded in 
accordance with convolution encoding. 
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Initially at step 2308, the first character in the selected line of the primary 
channel (with characters d, c 2 , c 3 , ...) is identified as the current character c>. 
Subsequently at step 2308, a recurrence or state change function hi=H(h M ,c[1 ,i]) 
is computed, where h 0 = 0, h M is the previous value in the chain, and Cj is the 
current character. Even though the state change function H(h H ,c[1,i]) may 
depend on any of the preceding characters (i.e., c[1,i] = c 1( c 2 , c 3 , ... q), the state 
change function often has a simple form such as ^(hM.Ci). In one embodiment, 
the state function is implemented using a simple shift register as described in 
"Fundamentals Of Convolutional Coding," by Johannesson et al., Institute of 
Electrical and Electronics Engineers, Inc., 1999 (ISBN: 0-7803-3483-3), which is 
incorporated herein by reference. In alternate embodiments, more complex hash 
functions can be implement such as MD5 as described in Applied Cryptography, 
by Bruce Schneier, John Wiley & Sons, ISBN 0-471-11709-9, which is 
incorporated herein by reference. In selecting a hash function, it is desirable that 
the hash function have a large enough range (e.g., greater than 2 32 ) so that the 
probability of different inputs having identical outputs is extremely small (e g 2" 
32 ). 

If the last character in the current line has not been reached at step 2310, 
then at step 2312 a guard extractor function gi=G(hj,c[1,i]) is used to compute a 
guard value (i.e., gi) for the state change function of the current character q. 
Even though the guard extractor function G(hi,c[1,i]) can depend on all preceding 
characters (i.e., c 1( c 2 , c 3 , ... q), the guard extractor often has the simple form 
<3(hi,qi), where q i( which may depend on any number of preceding characters 
(i.e., d, c 2 , c 3 , ... ci), is a bit selector that identifies the number of bits of the 
guard value. The inputs of the guard extractor function G include hi (e.g., the 
hash of the current character) and c[1,i] (i.e., previous characters, including the 
current character). Subsequently at step 2314, the current character is assigned 
to be the next character in the current line and step 2308 is repeated. 

Figure 24 illustrates a simplified embodiment of the computation of the 
state change function and the guard extractor function for a current line of a 
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primary channel 2406 (i.e., "This") for the case where q F 1 . Each character of the 
primary channel 2406 is represented by character code 2408 (i.e., c 1; c 2 , c 3 , and 
c 4 ). In this embodiment, the guard extractor function is hardcoded to always 
selects the low order bit (i.e., q i= 1) of the output of the one-way hash function 
2404 (i.e., hi) for all guard values in the chain except for the last guard value (i.e., 
g n ), which is selected in its entirety (i.e., all bits). This embodiment illustrates that 
the guard values 2410 produced as output to the guard extractor function can be 
fixed for a particular encoding scheme. 

Figure 25 illustrates a more generalized representation of the recurrent 
computation performed at steps 2308 to produce guard values 2501 at step 
2316 for each corresponding character code 2503 in a line of a primary channel. 
In this embodiment, the guard extractor functions G(h i; c[1,i]) 2502 receive input 
from the corresponding state change functions 2504 (i.e., hj=H(hM, Ci)). The 
number of bits selected of the output of the state change function 2504 of the 
current character hi depends on the cumulative uncertainty in the value of the 
characters c[1 ,i] (i.e., the more certain the fewer the number of bits selected). 
This uncertainty is quantified for each guard value by the value q (> which is used 
to select a variable number of bits from each state hi to define the guard value(s) 
9i- 

Referring again to Figure 23, if the last character in the current line has 
been reached at step 2310, then the guard value g n is computed at step 2311. 
Subsequently, the assist channel is augmented at step 2316 from the current 
line with the computed guard extractor functions (i.e., g-i ... g n ). If the selected 
line is not the last line in the primary channel at step 2318, then the current line 
is assigned to be the next line in the primary channel at step 2320 and step 2306 
is repeated; otherwise, the assist channel is encoded as machine-readable 
information using for example data glyphs at step 2324, as shown for example in 
Figure 10. Finally at step 2326, the primary channel and assist channel are 
concatenated and rendered on a hardcopy document using for example a printer 
108 shown in Figure 1. 
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E.2 Assist Channel Convolution Decoding 

Figure 26 illustrates a flow diagram that sets forth the steps performed by 
the hardcopy assist channel shown in Figure 2 for decoding a scanned hardcopy 
document with a convolution encoded assist channel. Initially at step 2602, a 
bitmap image 206 is acquired using a scanner of hardcopy document 1 06. The 
hardcopy document 106 in this instance includes a primary channel 124 and a 
convolution-encoded assist channel 126. At step 2604, the image extraction 
module 210 extracts the assist channel 1 18 and the bitmap primary channel 214 
from the bitmap image 206. The assist channel 1 18 is decoded at step 2606 by 
module 212. Subsequently at step 2610, each line of the bitmap primary channel 
is decoded using the decoded assist channel. Once the decoder module 216 
completes at step 2612, a decoded primary channel 112 can be viewed in 
electronic form on display 104 as 1 14 in document 102. 

Figure 27 is a flow diagram that sets forth the step 2610 shown in Figure 
26 in greater detail. At step 2702, a priority queue is initialized with an empty 
candidate C=(c'=0, h'=0, s'=0) for the current line of the primary channel, where 
c , =ci , c 2 '...Ci.i' is the possible interpretation of a prefix of the current line of text, h' 
is the value of the state change function after processing the possible 
interpretation c\ score s' measures the quality of the possible interpretation c' of 
the line of the primary channel, and k' is the location of the current guard value 
for the current candidate. 

At step 2704, the candidate with the best score is removed from the 
priority queue and defined as the current candidate C be st, where C be st's 
interpretation of the prefix of the line is c^d'ca'-.-Ci-i'. At step 2708, all extension 
characters ci' (i.e., decoded characters) of the prefix of the line c' = c 1 'c 2 '...cm' of 
the current candidate C bes t are identified. In addition at step 2704, let hiV be the 
current hash of the candidate, sm' be the current score of the candidate, and k' 
be the position the first unmatched guard value in the assist channel. In addition 
at step 2708, each possible extension character q' is scored against the 
remaining portion of the current line of the primary channel, thereby obtaining a 
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new score S\ = sm'+ S(Cj'). At step 2710, values for the state change function hj'= 
H(hi',Ci'[1,i]) and the guard extractor function gi'=G(hi',c'[1 ,i]) are computed for 
each of the extension characters Cj' identified at step 2708. 

At step 2712, each of the extension characters c' identified at step 2708 
that has a computed guard extractor function g' computed at step 2710 that 
equals the guard value gi in the assist channel beginning at the position ki, are 
added to the priority queue as candidates C nex t (c'= ^^'...Ci', hj', Sj', ki). At step 
2714, if the computed guard value g,' is equal to the last guard value g n in the 
assist channel for the current line, then the end of the current line of the primary 
channel has been reached and step 2716 is executed. Otherwise, step 2704 is 
repeated for the next best candidate. At step 2716, if all lines in the bitmap 
primary channel have been processed then step 2610 advances to step 2612. 
Otherwise, the current line is advanced to the next line spacing at step 2716, and 
the step 2702 repeats. 

Figure 28 illustrates a graphical representation 2802 of the method for 
decoding the current line 2406 of the primary channel shown in Figure 24 
according to the steps shown in Figure 27. Initially, the graph is defined by the 
empty candidate 2803. The extensions 2804-2807 for the first character space 
are identified. Note that of the extensions 2804-2807, only the extensions 2804 
and 2807 are added to the priority queue because their guard values agreed with 
the guard value in the assist channel (i.e., gi'=gi). Subsequently, the extension 
2807 is selected during the next iteration because it had the highest computed 
score. The bitmap of the primary channel 2406 is decoded with four iterations of 
the steps shown in Figure 27. The best candidate on the priority queue selected 
at the start of each iteration are identified by reference number 2807, 2810, 
2812, and 2814. It will be appreciated by those skilled in the art that convolution 
decoding techniques other than systematic decoding techniques can be used to 
carry out the invention such as Viterbi or list decoding techniques, as disclosed 
in "Fundamentals Of Convolutional Coding," by Johannesson et al., Institute of 
Electrical and Electronics Engineers, Inc., 1999 (ISBN: 0-7803-3483-3). 
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E.3 Modulated Assist Channel Convolution Coding 

Figure 29 illustrates the convolution coder shown in Figure 25 with 
integrated separation coders 2902 and separation code compressors 2904, 
which is referred to herein as "modulated convolution coding". In this 
embodiment the assist channel protects symbols printed on the hardcopy 
document by scrambling the compression of the separation codes using guard 
values that are derived from a hash of the character code of each character in 
the primary channel. When decoding, the descrambled separation codes allow 
errors to be readily avoided when template match searches are performed. 

Similar to the embodiment shown in Figure 25, the state change functions 
2504 and the guard extractor functions 2502 produce guard values 2501 (i.e., g 1f 
... g n ). In contrast, however, the embodiment shown in Figure 29 scrambles the 
production of compressed separation codes 2908 (i.e., cdi, ... cd n ) using the 
guard values 2501 (i.e., g u ... g^). The compressed separation codes 2908 are 
encoded in the assist channel along with the guard value g n . 

That is, similar to the convolution coding described above, state change 
functions 2504 are generated via the recursion of the state change function 
hj=H(h M ,Ci). However, rather than sampling this state change function and coding 
the results in the assist channel, a sample of the state change function is used to 
modify a coding of the assist channel that is based on separation coding. The 
manner in which the state change function is used to modify the assist channel 
depends on how the separation coding is compressed. 

As illustrated in Figure 29, the character codes 2503 are input to the 
separation coders 2902, which produce as output the separation codes 2906. In 
one embodiment, the separation coders 2902 encode the character codes of the 
primary channel in the manner set forth in Section C above. The separation code 
compressors 2904 in one embodiment compress the separation codes 2906 
using a modified arithmetic encoding technique, an example of which is 
described by Witten et al., in "Arithmetic Coding for Data Compression," Comm. 
ACM Vol. 30, Issue 6, pp. 520-540, 1987. In this embodiment, equivalence class 
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labels of the separation codes are compressed with an arithmetic encoding 
technique that is based on the likelihood of the equivalence classes. 

More specifically, encoding the extended convolution assist channel 
requires a first encoding and a second encoding of each line of the primary 
channel. A first encoding is performed for a given text string Ci, c 2 , c 3 , ... c n of the 
primary channel to classify the characters of the text string into equivalence 
classes zi, z 2 , z 3 , ... z m (e.g., group labels a, b, c in Figure 7) and obtain a 
reduced string of class labels di, d 2 , d 3 , ... d n , where dj is one of zi, z 2 , z 3 , ... z m . 
An arithmetic compressor can be described as a computation on intervals: if P(Zj) 
is the probability of the equivalence class labeled Zj, then the interval [0,1) is 
partitioned into subintervals [so,^), [s^), where Sj is the cumulative sum of 
the probabilities: Sj = Sj<iP(Zj). This provides a width P(zO for the i th subinterval 
that corresponds to the i th equivalence class. Without loss of generality, it is 
assumed that the intervals are ordered largest (most likely) to smallest. The 
string of class labels di, d 2 , d 3 , ... d n is compressed by the recursion: 

r 0 = [0,1), and 
r i =S(r i _ lt [s di _ 1 ,s di )), 

where S is the interval selector operator: 

S ([x, y),[a,b)) = [x + a(y - x), x + b(y - x)) . 

The selection operator S selects the interval [x',y') within the current interval [x,y) 
in the same proportion that the interval for dj's equivalence class [s rf _i,s rf ) 
corresponds to the interval [0,1). In this way the interval n uniquely determines 
the string of class labels di, d 2 , d 3) ... d n , and requires the ceiling of 
(log(P(d 1 )P(d 2 )P(d 3 )...P(d i ) + 1 bits to be specified. 

A second encoding is performed for the given text string c^, c 2 , c 3 , ... c n , of 
the primary channel to compute the corresponding state change functions hi, h 2 , 
h 3 , ... h n . In one embodiment, hi is sampled with a binary valued function G, such 
that it is equally likely that G(hj) equals zero or one. Subsequently, as shown in 
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Figure 29, the output of the state change function are used to modify the 
arithmetic encoders 2904 by permuting the selection intervals. For a partition of 
[0,1) into subintervals [so.sO, [si,s 2 ), ... , a permutation \i is defined such that 
[\i(s 0 ), |i(si)), Oifo), \i(s 2 )), Ms 2 ), \i(Sa)), ... , is also a partition that covers [0,1), 
and the interval length is preserved as: ll^(s i+1 )- ji(Si) II = ||s i+1 - $ II. A 
permutation operator is defined to depend on a single bit, which is supplied by 
the state change function, as follows: 



The permutation u. is chosen to provide as large a desynchronization as possible. 
When the first interval is greater than 1/2, the reversal permutation (i(x) = 1 - x is 
sufficient. When the largest interval is less than 1/2 it is desirable to choose a 
permutation such that no interval overlaps itself in the image of the permutation. 
With the operator R(g,[a,b)), the arithmetic compression recursion may be 
rewritten as: 

r 0 =[0,l), 

r l =S(r J _ 1 ,U(G(^ 1 ),[5 - ,_ 1 ,^)). 

Figure 30 illustrates an example of the scrambling the compression 2904 
of the separation codes 2906 using the guard values 2501 . In Figure 30, a string 
of separation code (or class) labels "a", "b", and "c" are encoded with real 
numbers between zero and one. The assigned probabilities for each of the class 
labels a, b, and c is in the proportion 1/2 to 1/3 to 1/6 to define intervals 3002 
(i.e., 0 to 0.5, 0.5 to 0.833, 0.833 to 1.0). This example shown in Figure 30 
assumes that the string of class labels being encoded begins with a "b" and 
follows with an "a". Beginning with the "b" class label, the selected interval is 
[0.5,0.833). The subsequent interval is selected from either intervals 3004 or 
intervals 3006. These intervals are flipped depending on whether the computed 
single-bit guard value g-i is equal to one or zero. Following with the "a" separation 
code, the subsequent interval is defined by the range of values 3008 or 3010 
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depending on whether the guard value equals zero or one, respectively, at 
3012, thereby scrambling the compression of the separation code, based on the 
guard value. 

Figure 31 is a flow diagram that sets forth the details of step 2610 shown 
in Figure 26 for decoding each line of the primary channel with a scrambled 
convolution coded assist channel. Similar to step 2702 shown in Figure 27, step 
3102 initializes a priority queue with an empty candidate C 0 . Subsequently at 
step 3104, the candidate, defined as C be st, is removed from the priority queue 
similar to step 2704, except that the current state of the compressors 2904 is 
recorded as r M \ At step 3106, the separation code label di' is decompressed 
using the compressed separation code label cdi from the assist channel, the 
previous state of the compressor n.-,, and the previous guard value gM. The 
separation code label di' is the computed separation class for the next extension 
character of the prefix of the line c'. 

At step 3108, all extension characters Cj' of C bes t are identified, where C\ is 
in the computed separation class labeled dj. In addition at step 3108, each 
possible extension character cT that is identified is scored against the remaining 
portion of the current line of the primary channel, thereby obtaining a new score 
Si' = sm' + S(Cj'). Finally at step 3112, the candidates C ne xt for all identified 
extensions cT are added to the priority queue. Note that steps 3114, 3116, and 
3118 correspond to steps 2714, 2716, and 2718 shown in Figure 27 and 
described above. 

Thus, unlike the decoding technique shown in Figure 27, which eliminates 
from the priority queue those candidates whose computed guard values do not 
match the guard values in the assist channel, the decoding technique in Figure 
31 eliminates candidates that are not in the correct separation class. However, 
the algorithms of Figures 27 and 31 are similar in that decoding errors in a 
particular candidate will cause all extensions of that candidate to score poorly. In 
Figure 31 , after an error in the candidate, the separation class di decompressed 
at step 3106 will be more nearly random, rather than correct, so there will be a 
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significant probability the best extension will not be explored in step 3108, and 
consequently lowering the score of extensions of a candidate containing an 
error. 

It will be appreciated by those skilled in the art that it is possible to link the 
5 computation of the state change function with a variety of compression 
algorithms. The general idea is behind this approach is to have the values of the 
state change function modify the functioning of the compression algorithm in a 
way that does not affect the quality of the compression achieved, but scrambles 
the results of the decompression after an error occurs. For example, a Ziv- 
10 Lempel-Welch compressor could be modified to scramble compression by 
XORing a subset of the bits of the state change function h M with the 
compressor's dictionary index before coding. 

F. Alternate Operating Environment Using A Rewrite Model 

In the operating environment set forth in Section A, the shortest path of 
15 the DID-style decoder is modified to account for the information in the assist 
channel. In this manner, the decoder is modified to find the shortest path by 
identifying matching solutions that are consistent with the information in the 
assist channel. That is, the shortest path computations performed in the 
operating environment of the decoder shown in Figure 2 can be incrementally 
20 applied to find the shortest path that is consistent with decoding errors corrected 
by the assist channel. 

Figure 32 illustrates an alternate embodiment of the hardcopy assist 
channel 204 shown in Figure 2. In this alternate embodiment, the assist channel 
operates independent of the decoder module 3204. Thus, in this alternate 
25 embodiment, the assist channel need not be integrated with any particular OCR 
decoding process. Instead, an assist channel is input to a rewrite module that 
models decoder errors independent from any OCR engine that performs the 
initial decoding of a bitmap image. 

Similar to the embodiment shown in Figure 2, the image extraction 
30 module 210 in Figure 32 receives bitmap image data 206 and separates the 
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assist channel 1 18 data from bitmap primary channel 214 data. However, in this 
embodiment, the decoder module 3204 decodes the bitmap primary data 214 
without support from the decoded and decompressed assist channel 219 to 
produce candidate primary data 3202. Also in this embodiment, a rewrite module 
3200 takes as input the candidate primary data 3202 and the decoded and 
decompressed assist channel 219 to produce the primary channel of data 1 12. 

In operation, the rewrite module 3200 defines a graph of the candidate 
primary data 3202 using an event library. The event library is used to build a 
failure model for the OCR engine in the decoder module 3204 by measuring the 
probability of various failure events that may occur during OCR processing. 
These failure events may be general (i.e., have a tendency to occur in all OCR 
engines) or specific (i.e., have a tendency to occur only in certain OCR engines). 
For example, Figure 33 illustrates an event library 3302 that sets forth specific 
rules 3304 and more general purpose rules 3306, which include catchall rules 
3308. Weights 3310 are assigned to each rule. The lower the weight the more 
likely that event will occur in the decoder module. Consequently, the identity 
transform 3312 (i.e., the do nothing transform) may have the lowest or one of the 
lowest assigned weights. One example of a failure event is event 3314 (i.e., 
rn->m), which defines a corrupted occurrence (i.e., "rn") and its correction (i.e., 
"m"). 

In one embodiment, the failure model is a weighted finite state transducer 
with a simple structure that includes a single state with a transition returning to 
that state. Because of the simplicity of the weighted finite state transducers in 
this embodiment, it is not necessary to treat the failure model with the fully 
generalized formulation of a weighted finite state transducer. In an alternate 
embodiment, a more generalized formulation of a weighted finite state 
transducer that incorporates a language model, as described by Jones et al. in 
"Integrating Multiple Knowledge Sources in A Bayesian OCR Post-Processor", 
Proc. of ICDAR 91 Saint-Malo, France, Volume 2, pp. 925-933, which is 
incorporated herein by reference, is employed. This more generalized 



-42- 



formulation of a weighted finite state transducer accounts for the rewrite 
module's inability to access any language model built into the OCR engine of the 
decoder module. 

With the failure model defined in the event library 3302, the rewrite 
5 module 3200 rewrites the candidate primary data 3202 decoded by decoder 
module 3204 with the assistance of the assist channel 219. In one embodiment, 
rewriting is performed by computing the shortest path (using dynamic 
programming using a Viterbi algorithm) of the candidate primary data 3202 using 
the failure model and the assist channel. This rewrite operation finds the most 
10 likely primary channel data 112. In other words, this shortest path computation 
provides a surrogate for the shortest path computation in the DID OCR engine 
operating in the decoder module 216 discussed above, thereby allowing the 
assist channel to be applied to any OCR engine that may operate in the decoder 
module 3204. 

15 As set forth above with reference to Figure 12, computation of the 

shortest path includes steps for defining a graph and steps for computing the 
shortest path. In this embodiment of the DID OCR engine, the steps for defining 
a graph are set forth in Figure 34 at reference number 3400. Once a graph is 
defined using steps 3400, the shortest path of the graph is computed using steps 

20 1201 shown in Figure 12, which are discussed in detail above. 

The steps 3400 shown in Figure 34 for defining a graph include step 3402 
that defines a node in the graph at every character (or symbol) position in a line 
of text from the candidate primary data 3202. In other words, nodes in the graph 
correspond to each text position in the candidate primary data. At step 3404, 
25 each node the event library 3302 is searched and when the left hand side of an 
event matches the string beginning at the node (i.e., the current node), an arc is 
added. The score of the arc is the weight of the event. The destination node of 
the arc has a position equal to the position of the current node plus the number 
of characters in the left hand side of the matched event. 
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Figure 35 illustrates an example of a graph defined in accordance with the 
steps set forth in Figure 34. The candidate OCR interpretation 3505 is computed 
using for example a DID OCR engine from an extracted bitmap primary channel 
3503. At every character position 3506 in the candidate OCR interpretation 3505, 
5 a node 3504 in the graph 3502 is defined (step 3402). Arcs are drawn between 
the nodes in the graph and assigned a rewrite and a score when the string 
defined by the character positions beginning at a node matches a string in the 
event library. For example, the arc 3508 is given a score and a rewrite (i.e., "m") 
for the match between the string of characters "rn" in the candidate OCR 
10 interpretation 3505 and the string 3314 in the event library 3302 (step 3404). 
Note that the shortest arcs in the graph 3502 are the identity transformation 3312 
defined in the event library. 

In an alternate embodiment, the decoder module 3204 includes with the 
candidate primary data 3202 delivered to the rewrite module 3200 other OCR 
15 data such as certainty estimates. In one embodiment, these certainty estimates 
are incorporated into the arc score at step 3404. Thus, although the decoder 
module 3204 and the rewrite module 3200 operate independent of each other, 
the rewrite module 3200 may take advantage of other statistical information that 
may be provided by the decoder module 3204. 

20 Figure 36 illustrates decoding of the graph defined in Figure 35 with the 

steps 1201 set forth in Figures 11 and 12. In the example shown in Figure 36, a 
product graph 3600 is defined in a similar manner to the product graph defined in 
Figure 16. The steps set forth in Figure 1 1 for decoding a primary channel using 
an assist channel encoded using separation codes can be applied to rewrite the 

25 candidate OCR interpretation, except that each line of the primary channel 
acquired at step 1110 corresponds to a line in the OCR interpretation 3505 and 
not the bitmap primary channel 214. 

For illustrative purposes the example of the decoding of the graph defined 
in Figure 36 sets forth only the first four symbols of Figure 35. Also, for simplicity 
30 only a few arcs are shown in Figure 36 to illustrate how the product graph 3600 
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is formed. In accordance with separation decoding described in detail above, a 
first dimension 3602 of the product graph 3600 is defined. It will be appreciated 
by those skilled in the art that the rewrite module 3200 does not perform a 
shortest path computation of the graph in the first dimension 3602, but rather a 
5 shortest path computation in the product graph. 

As shown in Figure 36, the output of the unassisted decoded primary 
channel 3606 (i.e., candidate primary data 3202 - characters "Fdbw") is 
corrected using the assist channel in the product graph 3600 to produce 
corrected output 3620 (i.e., primary channel data 112 - characters "Follow"). In 

10 defining the product graph, the rewrite module 3200 identifies both a character 
position in the candidate OCR interpretation 3602 and a position in the 
corresponding assist channel 3604. The example assist channel shown in Figure 
36 is defined using separation codes arranged in the three groups shown in 
Figure 7. In defining the product graph 3600, arc 3608 is excluded from the 

15 product graph because the character "d" falls in the separation group "a" and not 
the separation group "b" as required by the second position of the assist channel 
at arc 3610. However, note that although the arc 3612 satisfies the fourth 
position 3613 of the assist channel, the subsequent arc 3614 does not satisfy the 
fifth position 3615 of the assist channel. Once the product graph 3600 is defined, 

20 computing the shortest path of the product graph produces the output string 
3620, which includes characters "Follow". 

It will be appreciated by those skilled in the art that the rewrite module 
need not be limited to operate using separation coding as shown in Figure 36. 
Instead, the rewrite module may operate in accordance with block coding and 
25 convolution coding as discussed above with reference to the operating 
environment shown Figure 2. Also, those skilled in the art will appreciate that the 
same manner in which convolutional coding performed by the decoder module 
216 shown in Figure 2 modifies a graph (e.g., the graph 1602 shown in Figure 
16) into a tree (e.g., the tree 2802 shown in Figure 28), the rewrite module 3200 
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shown in Figure 32 operating with a convolutional rewrite module would modify 
the graph 3602 shown in Figure 36 into a tree. 

It will be further appreciated by those skilled in the art that the rewrites of 
the candidate primary data by the rewrite module are likely to be meaningless 
(i.e., the identity transform) unless the rewrite operations are performed with the 
assistance of the assist channel, since the character or symbol in the primary 
channel decoded by decoder 3204 should be more likely than any other event 
identified by the failure model. As a result, the failure model becomes useful 
when the assist channel has restricted or corrected the characters appearing in 
the candidate primary data with the next best interpretation. Such restriction or 
correction of the candidate primary data may involve resynchronization of the 
data as shown in Figure 36 that are implied by the failures identified by the 
rewrite module (e.g., rn m). 

In summary, the more generalized hardcopy assist channel shown in 
Figure 32, which includes a rewrite module that uses the assist channel to 
correct OCR failures independent of the decoder module, may be less efficient 
than the integrated hardcopy assist channel shown in Figure 2. Inefficiencies 
arise in the generalized hardcopy assist channel because not all of the statistical 
information used by the OCR decoder will be known to the rewrite module. That 
is, the DID OCR engine that is integrated with an assist channel in Figure 2 is 
able to use more statistical information about alternative interpretations that are 
specific to the bitmap primary channel being decoded. In contrast, the rewrite 
module shown in Figure 32 has only available to it in the failure model statistical 
information of OCR failures that occur to any document in general. However, the 
primary advantage of the generalized hardcopy assist channel shown in Figure 
32 is that any of the assist channel decoding techniques (i.e., separation coding, 
block coding, or convolution coding) can operate in the rewrite module 
independent of the OCR engine selected to operate in the decoder module. It will 
be appreciated by those skilled in the art that other OCR engines that can 
operate in the decoder module besides the DID OCR engine discussed above, 
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include the OCR engine in TextBridge Pro Millennium produced by ScanSoft, 
Inc. (www.scansoft.com). 

G. Miscellaneous 

It will be appreciated that portions of the system embodying the present 
5 invention may be readily implemented in software using software development 
environments that provide source code that can be used on a variety of 
hardware platforms. Alternatively, portions of the system may be implemented 
partially or fully in hardware using standard logic circuits. Whether software or 
hardware is used to implement different portions of the system varies depending 
10 on the speed and efficiency requirements of the system and also the particular 
function and the particular software or hardware systems and the particular 
microprocessor or microcomputer systems being utilized. 

The invention has been described with reference to a particular 
embodiment Modifications and alterations will occur to others upon reading and 
15 understanding this specification taken together with the drawings. The 
embodiments are but examples, and various alternatives, modifications, 
variations or improvements may be made by those skilled in the art from this 
teaching which are intended to be encompassed by the following claims. 
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CLAIMS: 



1. A method for generating image data for rendering on a hardcopy 
document, comprising: 

identifying a primary set of symbol data; the primary set of symbol data 
5 providing a first channel of human readable information to be rendered on the 
hardcopy document; and 

computing a secondary set of encoding data from the primary set of 
symbol data; the secondary set of encoding data providing an assist channel of 
machine readable information to be rendered on the hardcopy document; 
10 wherein said computing further comprises: 

partitioning the primary set of symbol data into a plurality of groups; 
the plurality of groups classifying symbol data according to how likely the 
symbol data will occur in the hardcopy document, and 

developing the secondary set of encoding data by associating the 
15 symbol data with ones of the plurality of groups. 

2. The method according to claim 1, further comprising assigning an 
identifier to each of the plurality of groups that partition the primary set of symbol 
data. 

20 3. The method according to claim 1 , wherein the plurality of groups further 

classify the symbol data according to how likely symbol data in the primary set of 
symbol data are to be confused during processing of a scanned representation 
of the primary set of symbol data. 

4. The method according to claim 1 , further comprising compressing the 
25 secondary set of encoding data. 

5. The method according to claim 4, further comprising scrambling the 
compressed secondary set of encoding data. 
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6. The method according to claim 5, wherein said compressing is 
performed with arithmetic encoding. 

7. The method according to claim 4, wherein said scrambling further 
comprises: 

5 computing a hash hj for each symbol in the primary set of symbol data 

with a state change function H(h M , d), where hi-! is a previous occurrence of the 
state change function H for the symbol cm; and 

developing the secondary set of encoding data cdj for each corresponding 
symbol q by scrambling each separation code di with a guard value gi derived 
10 from the computed hash h,. 

8. The method according to claim 1, further comprising encoding the 
machine readable information with data glyphs. 

9. The method according to claim 1 , wherein the primary set of symbol 
data and the secondary set of encoding data are rendered by a printer on the 

15 hardcopy document. 

10. The method according to claim 1, wherein said partitioning further 
comprises: 

defining a graph with a node for each symbol in the primary set of symbol 

data; 

20 assigning a value to each of the nodes that quantifies how likely the 

symbol data will occur in the hardcopy document; 

interconnecting the nodes of the graph with arcs; and 

assigning a value to each of the arcs that quantifies how likely symbol 
data in the primary set of symbol data are likely to be confused during 
25 processing of the scanned representation of the symbol data. 

11. The method according to claim 10, wherein said partitioning further 
comprises iteratively compute a partition of the graph that maximizes a ratio of 
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the values of each of the arcs and the values of each of the nodes until achieving 
a desired benefit or entropy. 

12. The method according to claim 1, further comprising: 

recording a scanned representation of the hardcopy document that 
5 includes the primary set of symbol data and a secondary set of encoding data; 
and 

decoding the scanned representation of the hardcopy document by 
identifying a shortest path of a product graph of the scanned representation of 
the primary set of symbol data and the secondary set of encoding data. 

10 13. The method according to claim 12, wherein said decoding is 

performed using a shortest path computation. 

14. The method according to claim 13, wherein the shortest path 
computation comprises a two-pass dynamic programming computation. 

15. The method according to claim 14, wherein the shortest path 
15 computation further comprise defining a product graph. 

16. The method according to claim 15, wherein the product graph is 
defined by: 

identifying templates from a template library that matches the primary set 
of symbol data; 

20 defining nodes that correspond to both position in the primary set of 

symbol data and the secondary set of encoding data; and 

defining arcs that identify template matches of the primary set of symbol 
data that are consistent with the secondary set of encoding data. 

17. An apparatus for generating image data for rendering on a hardcopy 
25 document, comprising: 

means for identifying a primary set of symbol data; the primary set of 
symbol data providing a first channel of human readable information to be 
rendered on the hardcopy document; and 
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means for computing a secondary set of encoding data from the primary 
set of symbol data; the secondary set of encoding data providing an assist 
channel of machine readable information to be rendered on the hardcopy 
document; wherein said computing means further comprises: 

5 means for partitioning the primary set of symbol data into a plurality 

of groups; the plurality of groups classifying symbol data according to how 
likely the symbol data will occur in the hardcopy document, and 

means for developing the secondary set of encoding data by 
associating the symbol data with ones of the plurality of groups. 

10 18. The apparatus according to claim 17, wherein the plurality of groups 

further classify the symbol data according to how likely symbol data in the 
primary set of symbol data are to be confused during processing of a scanned 
representation of the primary set of symbol data. 

19. The apparatus according to claim 17, wherein said partitioning further 
15 comprises: 

means for defining a graph with a node for each symbol in the primary set 
of symbol data; 

means for assigning a value to each of the nodes that quantifies how 
likely the symbol data will occur in the hardcopy document; 

20 means for interconnecting the nodes of the graph with arcs; and 

means for assigning a value to each of the arcs that quantifies how likely 
symbol data in the primary set of symbol data are likely to be confused during 
processing of the scanned representation of the symbol data. 

20. The apparatus according to claim 17, further comprising: 

25 means recording a scanned representation of the hardcopy document that 

includes the primary set of symbol data and a secondary set of encoding data; 
and 
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means decoding the scanned representation of the hardcopy document 
by identifying a shortest path of a product graph of the scanned representation of 
the primary set of symbol data and the secondary set of encoding data. 
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ABSTRACT OF THE DISCLOSURE 

A system encodes a separate assist channel that carries only a small 
amount of additional information in a hardcopy document to compensate for 
failure of an OCR system to accurately reconstruct a scanned electronic version 
5 of the hardcopy document. The assist channel is encoded by mapping data from 
a primary channel of the document into a plurality of groups. The plurality of 
groups is used to classify the symbols of the primary channel by the likelihood 
that a character will occur and the likelihood that the symbols of the primary 
channel will be confused during OCR processing. 
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